

TITLE

METHOD FOR PREVENTING DATA CORRUPTION BY A FLOPPY DISKETTE  
CONTROLLER

5

BACKGROUND OF THE INVENTION

**Field of the Invention:**

This invention relates to a method for preventing data  
corruption, and particularly to a method for preventing data  
corruption by a floppy diskette controller (FDC).  
10  
15  
20

**Description of the Related Art:**

In a computer system, a Floppy Diskette Controller (FDC) is used to control the data transfer (write or read data) to or from the FDC, and to interface the computer's Central Processing Unit (CPU) with the physical diskette device. The FDC has the ability to monitor a variety of operations during the data transfer to and from a floppy diskette. When an abnormality or an error appears during the data transfer, the FDC signals a warning to the computer system to respond to the abnormality. For example, data may be re-transferred. However, due to design flaws, the FDCs provided by some manufacturers can not detect errors in some specific situations.  
25  
30

Adams, for example, has described a situation in the U.S. Patent 5,379,414 in which data loss and/or data corruption may routinely occur during data transfer to or from diskettes. Specifically, when the last data byte of a sector is transferred, if the last byte of a sector write operation is delayed too long, the next (physically

adjacent) sector of the diskette will also be destroyed. In general, the FDCs can not detect such an error.

In the U.S. patent, Adams also describes a solution for the problem mentioned above. The solution adopts a software-based approach to measure the delay time for the last data byte transfer to a sector of the floppy diskette. When the delay time exceeds a predetermined time, a warning signal is sent to the computer system, so that the FDC or computer system can start the respective process (for example, re-transferring data) to minimize the damage from data loss and /or data corruption. It is noted that the delay time is the time between the data request (DREQ) and data acknowledgement (DACK) signals of Direct Memory Access (DMA).

According to Adams' technique, only the last data byte is detected. However, all data in the transfer is probably lost and/or corrupted. For example, although the time delay does not happen on the last data byte transfer to a sector of the floppy diskette, all of the data is probably lost and/or corrupted due to the previous data write delay.

The data transfer between the personal computer and the FDC adopts DMA mode. When the data transfer is processed in DMA mode, a first-in first-out (FIFO) buffer device is used. During the data transfer of the FDC, the data is stored in the FIFO buffer device, such that the data is not normally lost and/or corrupted. However, Adams does not consider DMA mode with the FIFO buffer device.

As concerns DMA mode with the FIFO buffer device, according to Adams' technique, if the last byte of a sector write operation delay is detected, a warning is sent. The probability of the data loss and/or data corruption is

small, however, due to the FIFO buffer device. Therefore, a mistake for operating the FDC appears when adopting Adams' technique. Further, if the warning is sent frequently, efficiency in the FDC access is dramatically reduced.

5

#### SUMMARY OF THE INVENTION

Accordingly, an object of the invention is to provide a software control method for solving the problem of FDC-caused defects and detecting all possible error data in a computer system to reduce data loss and/or data corruption in write delay transfer to the FDC.

10

To realize the above and other objects, the invention provides a method for preventing the Floppy Diskette Controller (FDC) from causing data corruption in relation to the CPU, system interrupt clock, floppy disk, FDC and peripherals, the method as follows:

determining if a requested computer system operation accesses the data from an FDC;

measuring the time for DMA request (DREG) from the issue to the removal;

signaling an error from the computer system if the measured time exceeds a specific value.

20

The inventive method is accompanied by an interpose service routine pre-hooked to the interrupt vector, 25 intercepted by the system interrupt clock and accompanied by the raised system interrupt clock rate during measurement of the time.

#### BRIEF DESCRIPTION OF THE DRAWINGS

30

The aforementioned objects, features and advantages of this invention will become apparent by referring to the

following detailed description of a preferred embodiment with reference to the accompanying drawings, wherein:

Fig. 1 shows a typical computer system's architecture;

5 Fig. 2 shows the timing of data transfer of Fig. 1 under DMA mode;

Fig. 3 shows an embodiment of the FDC method according to the invention;

Fig. 4a is a measurement flowchart of the maximum interval value with an interpose service routine; and

10 Fig. 4b is an extract flowchart of the result from Fig. 4a.

#### DETAILED DESCRIPTION OF THE INVENTION

Fig. 1 shows a typical computer system's architecture. The computer system 10 has a central processing unit (CPU) 12 and a main memory 14 communicating with each other by a bus 15. During the duty cycle, the commands (e.g. an executable file, and so on) and data from the CPU 12 are stored in the main memory 14. The main memory 14 is capable of storing the data only during power-on, so a hard disk is added (not shown) to store the permanent data. Typically, a floppy disk drive 16 is essential equipment in a computer system like the system 10, in order to receive data from a removable floppy diskette 17.

25 In transferring data to the floppy diskette 17, the CPU 12 may program a DMA controller 18 for an input/output (I/O) transfer. The CPU 12 issues a command to a FDC 20 to begin the I/O transfer, and then waits for the FDC 20 to interrupt the CPU 12 with a completion interrupt signal.

30 The computer system 10 also has a system clock 22. For example, a timer 8253 is used as the system clock 22. The

system clock 22 interrupts the CPU 12 at a rate of 18.2 times per second, i.e. roughly once every 54.9 ms.

DMA controller 18 manages data transfer between the FDC 20 and the main memory 14. A DMA request (DREQ) is issued to DMA controller 18 when the computer system 10 requests a data transfer (for example, a data write) to the floppy diskette 17 in DMA mode. Likewise, a DMA acknowledgement (DACK) is returned from DMA controller 18 to the FDC 20. Next, DMA request (DREQ) is removed. At this point, the computer system 10, for example, issues a read/write signal (R/W; not shown in Fig. 1) to write the data to the floppy diskette 17.

Fig. 2 shows the timing of the data transfer from Fig. 1 under DMA mode. When DMA request (DREQ) is issued, DMA request (DREQ) is changed from logic "0" to logic "1". When DMA acknowledgement (DACK) is issued, DMA acknowledgement (DACK) is changed from logic "1" to logic "0". When DMA request (DREQ) is removed, DMA request (DREQ) is changed from logic "1" to logic "0".

In the mainboard of the computer system 10, DMA assignment preempts the FDC operations occurring on DMA channel 2 (which is lower priority than other DMA channels). Hence, while the floppy diskette 17 transfer is active in DMA mode, if the computer system 10 is busy for the concurrent transfer of data to or from a network, the delay time  $T_d$  from DMA request (DREQ) issued to DMA acknowledgement (DACK) returned is long to incur the data delay read from/write into the floppy diskette 17. In some I/O chips, the highest potential for data loss and/or data corruption is present when the delay time  $T_d$  ranges from about  $20 \mu s$  to about  $30 \mu s$ . If a FIFO buffer device (not

shown) is implemented in and enabled by the FDC 20 or DMA controller 18, the highest potential for data loss and/or data corruption is present when the delay time  $T_d$  exceeds about  $250 \mu s$  due to the temporary storage feature of the 5 FIFO buffer device.

Accordingly, the length of delay time  $T_d$  is an important indicator to determine if the read/write data is lost or corrupted for every byte of data transfer in DMA mode.

According to the Adams technique, only the last data byte of the DMA transfer is detected. The delay time  $T_d$  is measured before the last data byte is written to the floppy diskette 17 to determine if the time  $T_d$  exceeds a specific value, thereby determining the potential for data loss and/or corruption. Obviously, since the delay time  $T_d$  exceeding a specific value happens on the previous data byte (not the last data byte) from or to the floppy diskette 17, Adams' technique can neither handle it nor signal the system to respond to it. Also, if the FIFO buffer device in the DMA controller is enabled, the tolerance of the delay time  $T_d$  can become longer (e.g. from  $20 \mu s$  to  $250 \mu s$ ). However, the FIFO buffer device in DMA controller is not considered in the Adams' technique, this means that a normal transfer (i.e.  $20 \mu s < T_d < 250 \mu s$ ) may be determined as a data loss and/or data corruption so as to have an unnecessary response 25 (for example, to transfer data again) from the system. The operating performance of the floppy diskette 17 and computer system is therefore reduced.

Accordingly, the invention provides a method for preventing floppy diskette controller data transfer errors, 30 comprising the following steps:

(a) determining if a requested computer system operation is a floppy diskette operation;

5 (b) hooking an interpose service routine to provide the interrupt vector intercepted by an interrupt clock of the system;

(c) programming the system interrupt clock to interrupt faster than normal, wherein DMA request (DREQ) is detected for every interrupt issued by the system interrupt clock;

10 (d) initiating the floppy diskette service routine of the computer system to access the data in the floppy diskette;

(e) measuring the time interval for every DMA request (DREQ) from the issue to the removal and recording the maximum time interval value;

15 (f) if the maximum time interval value exceeds a specific value, the computer system issues a warning signal;

(g) reprogramming the system interrupt clock to interrupt normally.

The invention is described in detail as follows with reference to Fig. 3 and 4.

20 In general, INTEL and its compatible CPU can provide at least 256 interrupts, each having a specific usage. The interrupts corresponding to the invention are simply described as follows.

INT 13h is Floppy Diskette I/O service routine.

25 INT 8h is a hardware interrupt with the system clock or system interrupt clock continually interrupting every 54.9 microsecond, i.e. a frequency of 18.2 times/sec. In the interrupt routine of INT 8h, a designer can define or hook an interpose service routine desired in order to perform the motion defined by the interpose service routine when INT 8h

is issued (that is, INT 8h is intercepted by the system clock).

In step (b) mentioned above, in the embodiment, the invention intercepts INT 8h directly due to the speed consideration. The interpose procedure as shown in Fig. 4 is described in detail as follows.

Fig. 3 shows a of an embodiment of the FDC method according to the invention.

As shown in Fig. 3, when the computer system 10 starts floppy diskette driver access through the operating system (step 300) to access data.

In this embodiment, the floppy diskette driver introduces some complementary programs into the conventional floppy diskette service routine (step 303) to complete the control flow required by the embodiment.

Firstly, determine if the computer system 10 accesses the data to the floppy diskette 17 after starting the floppy diskette driver (step 301).

If the data access action is determined in step 301, (step 302) request the interrupt service of INT 8h to the computer system through the interrupt request IRQ 0 in order to re-define the system interrupt clock (or system clock) 22. The re-defined system clock 22 interrupts at an accelerated rate of 10 microseconds, faster than the normal interrupt rate of 54.9 milliseconds. Also, the accelerated flag SpeedUp is set to "TRUE" and the floppy diskette R/W flag FDD\_R/W is set to "TRUE".

Secondly, perform a conventional floppy diskette service routine (step 303). The central application configuration calls the respective function of the floppy diskette I/O service routine INT 13. Meanwhile, if a DMA transfer is

requested, the flag DMA2START of DMA channel 2 is set to "TRUE" (the system generally adopts the function of DMA channel 2 of DMA mode when accessing data from floppy diskette).

5 While step 303 is in progress, the system interrupt clock remains at the rate of 10 microseconds. DMA request (DREQ) is detected for every interrupt. That is, in this embodiment, the time interval value from the request issued (DREQ2=1) to the request removed (DREQ2=0) is detected and 10 the maximum delay time  $T_{delay\_max}$  therebetween is recorded.

The system interrupt clock 22 returns to the normal interrupt rate after the data transfer is completed (step 303 over). Step 304 determines if the floppy diskette service routine in step 303 has floppy diskette access (i.e. the floppy diskette R/W flag FDD\_R/W="TRUE" is determined). If FDD\_R/W="TRUE", step 305 is performed. In step 305, the flag FDD\_R/W is reset to "FALSE" and the respective complement of the system time (for the delay time) is performed.

20 In step 306, detect if a FIFO buffer device exists in the FDC 20 or DMA controller 18 is and enabled. If not, the computer system 10 issues an error signal when the maximum delay time  $T_{delay\_max}$  greater than a first specific value (e.g. 20 microseconds) appears (step 309). If yes, the computer 25 system 10 issues an error signal when the maximum delay time  $T_{delay\_max}$  is greater than a second specific value (e.g. 250 microseconds) appears (step 309).

Referring to Fig. 3 again, after the computer system 30 engages the floppy diskette driver (step 300), the computer system 10 directly performs the conventional floppy diskette service routine (step 303) to complete the data transfer if

the computer system 10 is not engaged in floppy diskette 17 access (rather, accessing the hard disk or other storage).

Figs. 4a and 4b show a measurement flowchart of the maximum delay time  $T_{delay\_max}$ .

5 The pre-defined interpose service routine (hereinafter, referred to as an interpose procedure) is performed by every request from the computer system 10 for the interrupt service of INT 8h through the signal IRQ 0. First, as the flag SpeedUp "TRUE" is determined by the interpose procedure 10 (step 401), the computer system 10 on the floppy diskette 17 is determined. Otherwise, the conventional interrupt routine of INT 8h is performed (step 406).

Sequentially, if the flag DMA2START of DMA channel 2 is determined not to be set as the logic "TRUE" (step 402), it determines if the flag DREQ2 of DMA request (DREQ) is "1" (step 403). If the logic of DREQ2 is not "1", it signifies that the computer system 10 cannot start data access to the floppy diskette 17 in DMA mode. If the logic "1" of DREQ2 is determined (step 403), step 404 is performed. In step 404, the flag DMA2START is set to "TRUE" and a maximum interval value  $TD_{MAX}$  is set to 0.

Sequentially, a measurement procedure is performed (step 405) to measure an interval count  $T_{CNT}$  (or the sampling point) of every foregoing DMA request from the issue to the removal before every byte of data is accessed in DMA mode. Therefore, a maximum delay time  $T_{delay\_max}$  is obtained as DMA transfer is over. The flags DMA2START and SpeedUp are reset to "FALSE". The system interrupt clock is returned to the normal rate.

30 Referring to Fig. 4b, in the foregoing measurement procedure (step 405), determine if the flag DREQ2 of DMA

request (DREQ) is "1" (step 405-a). If DREQ2= 1, the count  $T_{CNT}$  is increased by 1 (step 405-b), returning back to the operating system. Next, step 405-a is repeated at the rate of 10 microseconds. The count  $T_{CNT}$  is continuously increased by 1 (step 405-b) if DMA request (DREQ) is on the issued state (DREQ2=1).

Once DMA acknowledgement (DACK) is issued, the DMA request (DREQ) is removed (DREQ2=0). It is determined if  $T_{CNT} > TD_{MAX}$  as DREQ2=0 (step 405-c). When  $T_{CNT} > TD_{MAX}$ ,  $TD_{MAX} = T_{CNT}$  (step 405-d); otherwise,  $TD_{MAX}$  remains unchanged and  $T_{CNT} = 0$  (step 405-e) such that DREQ2 can measure the time with respect to the state of DREQ2=1 before another byte is accessed by the DMA mode.

The maximum interval  $TD_{MAX}$  obtained after step 405-e is completed is a maximum delay time  $T_{delay\_max}$  ( $= TD_{MAX} \times 10$  microseconds) of DMA request (DREQ) from the issue to the removal.

Step 405-f is to detect if DMA transfer is over. If not, step 405 repeats and re-accumulates the count  $T_{CNT}$  in order to find the interval  $TD_{MAX}$  when DMA transfer is over.

When DMA transfer is over, step 405-g is performed in order to reset the flags DMA2START and SpeedUp into "FALSE"; and recovers the system interrupt clock to an interrupt rate of the normal IRQ 0.

The maximum delay time  $T_{delay\_max}$  (i.e. a read or write delay) of DMA request (DREQ) from the issue to the removal before each byte is read out or written in the floppy diskette with DMA mode is found through the maximum interval  $TD_{MAX}$  obtained from the execution of Fig. 3, 4a and 4b. Therefore, the potential for data loss and/or data corruption in the data transfer is determined by determining

if the maximum delay time  $T_{delay\_max}$  is greater than a specific value (e.g. 20 microseconds or 150 microseconds with FIFO), thereby performing a specific process by the computer system according to the comparison result.

5 The inventive application carries distinct advantages as follows:

It is capable of detecting all possible error data;  
It provides more efficient transfer performance due to the FIFO;

10 In mainboard or system manufacture, it ensures mainboard quality and protects users from data loss and/or data corruption by detecting all possible FDC defection in advance;

For a defective FDC after the commerce, the user can eliminate the defect by modifying the driver or BIOS with the inventive method thus protecting the user from data loss and/or data corruption.

Although the present invention has been described in its preferred embodiment, it is not intended to limit the invention to the precise embodiment disclosed herein. Those who are skilled in this technology can still make various alterations and modifications without departing from the scope and spirit of this invention. Therefore, the scope of the present invention shall be defined and protected by the 25 following claims and their equivalents.